

66/67/99  
JC640 U.S. PTO

A

**UTILITY PATENT APPLICATION TRANSMITTAL  
(Large Entity)**

(Only for new nonprovisional applications under 37 CFR 1.53(b))

Docket No.  
PO9-99-014

Total Pages in this Submission

**TO THE ASSISTANT COMMISSIONER FOR PATENTS**Box Patent Application  
Washington, D.C. 20231

Transmitted herewith for filing under 35 U.S.C. 111(a) and 37 C.F.R. 1.53(b) is a new utility patent application for an invention entitled:

**AN APPARATUS FOR PROVIDING DIRECT DATA PROCESSING ACCESS USING A QUEUED DIRECT INPUT-OUTPUT DEVICE**

and invented by:

Michael E. Baskey, Steven G. Glassen, Eugene P. Hefferon, Bruce H. Ratcliff, Arthur J. Stagg and Stephen R. Valley

JC530 U.S. PTO  
09/25/99  
02/11/99

If a CONTINUATION APPLICATION, check appropriate box and supply the requisite information:

 Continuation     Divisional     Continuation-in-part (CIP)    of prior application No.: \_\_\_\_\_

Which is a:

 Continuation     Divisional     Continuation-in-part (CIP)    of prior application No.: \_\_\_\_\_

Which is a:

 Continuation     Divisional     Continuation-in-part (CIP)    of prior application No.: \_\_\_\_\_

Enclosed are:

**Application Elements**

1.  Filing fee as calculated and transmitted as described below
  
2.  Specification having 50 pages and including the following:
  - a.  Descriptive Title of the Invention
  - b.  Cross References to Related Applications (*if applicable*)
  - c.  Statement Regarding Federally-sponsored Research/Development (*if applicable*)
  - d.  Reference to Microfiche Appendix (*if applicable*)
  - e.  Background of the Invention
  - f.  Brief Summary of the Invention
  - g.  Brief Description of the Drawings (*if drawings filed*)
  - h.  Detailed Description
  - i.  Claim(s) as Classified Below
  - j.  Abstract of the Disclosure

# UTILITY PATENT APPLICATION TRANSMITTAL (Large Entity)

(Only for new nonprovisional applications under 37 CFR 1.53(b))

Docket No.  
PO9-99-014

Total Pages in this Submission

## Application Elements (Continued)

3.  Drawing(s) (*when necessary as prescribed by 35 USC 113*)
  - a.  Formal Number of Sheets \_\_\_\_\_
  - b.  Informal Number of Sheets 11
4.  Oath or Declaration
  - a.  Newly executed (*original or copy*)  Unexecuted
  - b.  Copy from a prior application (37 CFR 1.63(d)) (*for continuation/divisional application only*)
  - c.  With Power of Attorney  Without Power of Attorney
  - d.  **DELETION OF INVENTOR(S)**  
Signed statement attached deleting inventor(s) named in the prior application, see 37 C.F.R. 1.63(d)(2) and 1.33(b).
5.  Incorporation By Reference (*usable if Box 4b is checked*)  
The entire disclosure of the prior application, from which a copy of the oath or declaration is supplied under Box 4b, is considered as being part of the disclosure of the accompanying application and is hereby incorporated by reference therein.
6.  Computer Program in Microfiche (*Appendix*)
7.  Nucleotide and/or Amino Acid Sequence Submission (*if applicable, all must be included*)
  - a.  Paper Copy
  - b.  Computer Readable Copy (*identical to computer copy*)
  - c.  Statement Verifying Identical Paper and Computer Readable Copy

## Accompanying Application Parts

8.  Assignment Papers (*cover sheet & document(s)*)
9.  37 CFR 3.73(B) Statement (*when there is an assignee*)
10.  English Translation Document (*if applicable*)
11.  Information Disclosure Statement/PTO-1449  Copies of IDS Citations
12.  Preliminary Amendment
13.  Acknowledgment postcard
14.  Certificate of Mailing  
 First Class  Express Mail (*Specify Label No.:* EE355069788US)

**UTILITY PATENT APPLICATION TRANSMITTAL**  
**(Large Entity)**

*(Only for new nonprovisional applications under 37 CFR 1.53(b))*

Docket No.  
 PO9-99-014

Total Pages in this Submission

**Accompanying Application Parts (Continued)**

15.  Certified Copy of Priority Document(s) (*if foreign priority is claimed*)
16.  Additional Enclosures (*please identify below*):  


**Fee Calculation and Transmittal**

**CLAIMS AS FILED**

| For                                             | #Filed                   | #Allowed | #Extra | Rate             | Fee      |
|-------------------------------------------------|--------------------------|----------|--------|------------------|----------|
| Total Claims                                    | 22                       | - 20 =   | 2      | x \$18.00        | \$36.00  |
| Indep. Claims                                   | 2                        | - 3 =    | 0      | x \$78.00        | \$0.00   |
| Multiple Dependent Claims (check if applicable) | <input type="checkbox"/> |          |        |                  | \$0.00   |
|                                                 |                          |          |        | BASIC FEE        | \$760.00 |
| OTHER FEE (specify purpose)                     |                          |          |        |                  |          |
|                                                 |                          |          |        | TOTAL FILING FEE | \$796.00 |

- A check in the amount of to cover the filing fee is enclosed.
- The Commissioner is hereby authorized to charge and credit Deposit Account No. 09-0463  
 as described below. A duplicate copy of this sheet is enclosed.
- Charge the amount of \$796.00 as filing fee.
  - Credit any overpayment.
  - Charge any additional filing fees required under 37 C.F.R. 1.16 and 1.17.
  - Charge the issue fee set in 37 C.F.R. 1.18 at the mailing of the Notice of Allowance,  
 pursuant to 37 C.F.R. 1.311(b).



Lily Neff, Attorney  
 Reg. No. 38,254  
 IBM Corporation  
 Intellectual Property Law  
 522 South Rd., M/S P386  
 Poughkeepsie, NY 12601-5400

Dated: February 19, 1999

CC:

Docket Number: PO9-99-014

AN APPARATUS FOR PROVIDING  
DIRECT DATA PROCESSING ACCESS  
USING A QUEUED DIRECT INPUT-  
OUTPUT DEVICE

APPLICATION FOR UNITED STATES  
LETTERS PATENT

"Express Mail" Mailing Label No.: EE355069788US  
Date of Deposit: February 19, 1999

I hereby certify that this paper is being deposited with the United States Postal Service as "Express Mail Post Office to Addressee" service under 37 CFR 1.10 on the date indicated above and is addressed to the Assistant Commissioner of Patents, Washington, DC 20231.

Name: Susan L. Phelps

Signature: 

AN APPARATUS FOR PROVIDING DIRECT DATA PROCESSING  
ACCESS USING A QUEUED DIRECT INPUT-OUTPUT DEVICE

**FIELD OF INVENTION**

5       The subject of the present invention in general pertains to a new Input-Output facility design that exploits high bandwidth integrated network adapters.

**BACKGROUND OF THE INVENTION**

In a network computing environment, multitudes of commands and requests for retrieval and storage of data are processed every second. To properly address the complexity of routing these commands and requests, environments with servers have traditionally offered integrated network connectivity to allow direct attachments of clients such as Local Area Networks (LANs). Given the size of most servers, the number of clients usually is in the range of hundreds to thousands and the bandwidth required in the 10-100 Mbits/sec range. However, in recent years the servers have grown and the amount of data they are required to handle has grown with them. As a result, the existing I/O architectures need to be modified to support this order of magnitude increase in the bandwidth.

20       In addition, new Internet applications have increased the demand for improved latency. The adapters must support a larger number of users and connections to consolidate the network interfaces which are visible externally. The combination of all 25 the above requirements presents a unique challenge to server I/O subsystems.

Furthermore, in large environments such as International Business Machines Enterprise System Architecture/390 (Enterprise System Architecture/390 is a registered trademark of International Business Machines Corporation), there are  
5 additional requirements that the I/O subsystem must remain consistent with existing support. Applications must continue to run unmodified, and error recovery and dynamic configuration must be preserved or even improved. Sharing of I/O resources must be enabled as well as the integrity of the data being sent or  
10 received. This presents new and complex challenges that need to be resolved.

In order to achieve bandwidths which are dramatically higher and still achieve other required challenges, a new system  
15 architecture is needed.

This application is being filed on the same day as the following related applications: PO9-99-013, PO9-99-015, PO9-99-016, PO9-99-017, PO9-99-018, PO9-99-019, PO9-99-020, PO9-99-021, PO9-99-022, PO9-99-023, PO9-99-024, PO9-99-025, PO9-99-026, PO9-99-027, PO9-99-028, PO9-99-029, PO9-99-030, and  
20 PO9-99-031.

#### SUMMARY OF THE INVENTION

An apparatus for providing direct data processing access in a network computing system environment. The system environment  
25 has a main storage which can be connected to one or more application servers and is in processing communication with an interface element. The interface element has at least one adapter and can be connected to one or more application user(s). One or more queues are established in the main storage that can  
30 handle data without causing interrupts in the running programs.

Incoming data is received using the adapter and as data is received or modified, the status of the network computing system will be updated to reflect the new data or change. Data is then processed in the main storage after interrogating the multiple existing queues in the main storage simultaneously and forwarding them in turn to their appropriate destination or application server after a determination has been made by interrogating these queues.

BRIEF DESCRIPTION OF THE DRAWINGS

The subject matter which is regarded as the invention is particularly pointed out and distinctly claimed in the concluding portion of the specification. The invention, however, both as to organization and method of practice, together with further objects and advantages thereof, may best be understood by reference to the following description taken in connection with the accompanying drawings in which:

Figure 1 is an illustration of a network computing environment utilizing a channel subsystem and a control unit;

Figure 2 is an illustration of a network computing environment as per one embodiment of the present invention; Figure 2A shows how the use of some channel and control unit functions while Figure 2B shows the details of the Interface element;

Figure 3 is an illustration of a queuing mechanism as per one invention of the present invention;

Figure 4 illustrates SETUP SDU fields;

Figure 5A represents the format for the command request block for store-subchannel-QDIO data, while Figure 5B represents the format for the command response block for the store-subchannel-QDIO data command;

5       Figure 6 is an illustration of the format for Subchannel-QDIO description Block;

Figure 7 is a tabular illustration of the contents of input queues as per one embodiment of the present invention;

10      Figure 8 is a tabular illustration of the contents of output queues as per one embodiment of the present invention;

Figure 9 is an example of a queue information block content as per one embodiment of the present invention;

15      Figure 10 is an example of a SLIB block content as per one embodiment of the present invention;

Figure 11 is an example of a SLIBE block content as per one embodiment of the present invention;

Figure 12 is an example of a Storage List content as per one embodiment of the present invention;

20      Figure 13 is an example of a SBALE content as per one embodiment of the present invention; and

Figure 14 is an example of a Storage-List-State-Block content as per one embodiment of the present invention.

DETAILED DESCRIPTION OF THE INVENTION

An example of an existing data processing system architecture is depicted in Figure 1. As shown in Figure 1, information is passed between the main storage 110, and one or 5 more input/output devices (hereinafter I/O devices) 190, using channel subsystems 150. Through the switch 160, channel paths are established, comprising channels 155 and one or more control units shown at 180. These channel paths are the communication links established between the I/O devices 190 and the main storage for processing and exchange of information.

The main storage 110 stores data and programs which are input from I/O devices 190. Main storage is directly addressable and provides for high speed processing of data by central 15 processing units and one or more I/O devices. One example of a main storage is a customer's storage area and a system area (not shown). I/O devices 190 receive information or store information in main storage. Some examples of I/O devices include card readers and punches, magnetic-tape units, direct-access storage devices (DASD), displays, keyboards, printers, teleprocessing 20 devices, communication controllers and sensor-based equipment.

The main storage is coupled to the Storage Control Element (SCE) 120 which in turn is coupled to one or more central processing units (CPU) 130. The central processing unit(s) is 25 the control center of the data processing system and typically comprises sequencing and processing facilities for instruction execution, initial program loading and other related functions. The CPU is usually coupled to the SCE via a bi-directional or uni-directional bus. The SCE, which controls the execution and 30 queuing of requests made by the CPU and channel subsystem, is coupled to the main storage, CPUs and the channel subsystem via

different busses.

The channel subsystem directs the flow of information between I/O devices and main storage and relieves the CPUs of the task of communicating directly with the I/O devices so that data processing operations directed by the CPU can proceed concurrently with I/O processing operations. The channel subsystem uses one or more channel paths as the communication links in managing the flow of information to or from I/O devices. Each channel path consists of one or more channels, located within the channel subsystem, and one or more control units. In one preferred embodiment, a SAP I/O processor is also included as part of the channel subsystem.

As can be seen in Figure 1, it is also possible to have one or more dynamic switches or even a switching fabric (network of switches) included as part of the path, coupled to the channel(s) and the control unit(s). Each control unit is further attached via a bus to one or more I/O device(s).

The subchannel is the means by which the channel subsystem provides information about associated I/O devices to the central processing units; the CPUs obtain this information by executing I/O instructions. The subchannel consists of internal storage that contains information in the form of a channel command word (CCW) address, channel path identifier, device number, count, status indications, and I/O interruption subclass code, as well as information on path availability and functions pending or being performed. I/O operations are initiated with devices by executing I/O instructions that designate the subchannel associated with the device.

The execution of input/output operations is accomplished by the decoding and executing of CCWs by the channel subsystem and input/output devices. A chain of CCWs (input/output operations) is initiated when the channel transfers to the control unit the command specified by the first channel command word. During the execution of the specified chain of I/O operations, data and further commands are transferred between the channel(s) and the control unit(s).

As explained earlier, in order to achieve bandwidths which are dramatically higher and move from 100 Mbits to Gbit technologies, a combination of improvements is required.

Figure 2 depicts the network environment of the present invention. Figure 2A depicts how the existing channel subsystem and control units is replaced by an Interface element as shown at 200 along the path 210. A Connector Interface Element and a Network Interface Element are also components of the Interface element as shown at 240 and 260 respectively. The present invention still allows the use of most programming and code structure of the existing architecture, but provides a much faster and more efficient system by bypassing the need for addressing many of the existing required functions such as the multitudes of channel commands, by eliminating the need for many processing steps.

The architecture of the present invention can be better depicted in the configuration represented by Figure 2B. The Connector Interface Element shown at 240 can include a plurality of processors, at least one of which is used for redundancy purposes and bus interface cards. An direct memory attached I/O device such as a Self-Timed Interface bus, hereinafter STI bus (shown at 230) as used in one embodiment of the present

invention, connects the Connector Interface element to the main storage 110 (also referenced to as the host) which in turn can be connected to a variety of other network elements and servers shown at 220 such as web-servers and other TCP/IP oriented servers. The Connector Interface Element is in processing communication with the Network Interface Element shown at 260 via another direct memory attached I/O device such as a Peripheral Controller Interface bus, hereinafter PCI bus as shown at 250 as used in one embodiment of the present invention. The I/O device adapters, at least one or more processors and some local storage reside in the Network Interface Element. Consequently, the Network Interface Element is connected to individual application users depicted at 270 such as Lotus Notes clients and Web browsers.

Data streams and requests for retrieval of data from servers by the application users is transferred via the Interface Element to the main storage where a plurality of queues can be setup for processing and storage of the data while providing the advantage of bypassing any need for causing an interrupt in the main program. The status of the network is then updated to reflect the changes. Once the appropriate response or data is retrieved from the servers, these multiple queues are interrogated simultaneously to determine the appropriate application server that the data needs to be sent to. Subsequently, data from the servers is also transmitted via the Interface Element to the application users in the same manner by establishing and interrogating the queues.

The queuing mechanism needs to be explained in more detail. The queuing mechanism of the present invention is referenced to as the Queued Direct I/O (QDIO) facility and comprises communication stacks. The input and output queues or both may be

provided. When the QDIO input queues are provided, the program can directly access data placed into the input queues by the adapter(s) of the Interface Element. Typically, the source of the data placed into such input queues originates from an I/O device or network of devices to which the adapter is connected. Correspondingly, when the QDIO output queues are provided, the program can transmit data directly to the adapter by placing data into the appropriate output queues. Depending on the adapter, the data placed into such output queues may be used internally by the adapter or may be transmitted to one or more I/O devices to which the adapter is connected.

The build in queues set are located in the program storage and are separate from the data control traffic. In a preferred embodiment up to 240 queue sets are provided. A direct adapter storage interface is also provided to minimize interrupts and other overhead. Each queue set in the mechanism provides for separate outbound and inbound queues; in one preferred embodiment, four outbound and at least one inbound queue. Each application is assigned to at least one queue set which comprises a number for input or output queues, and each queue set can share one or more adapters. The queue sets provide for a list of useable buffers and also a list of storage blocks for incoming/outgoing data. The buffers are further prioritized to address specific application needs. At initialization time and subsequently when desired or a change is required, queues are initiated for each application(s). Queues are naturally static at initialization time when they are flexibly defined but as new applications are being assigned, the queuing becomes dynamic and updates are made at intervals or continuously, as desired, to reflect the latest nature of them.

For both QDIO input and output queues, main storage is used as the medium by which data is exchanged between the program and the adapter. Additionally, these queues provide the ability for both the program and the adapter to directly communicate with each other in an asynchronous manner which is both predictable and efficient without requiring the services of a centralized controlling mechanism, such as an Operating System Input/Output Supervisor, and the resulting overhead such a control mechanism implies. Both input and output queues are constructed in main storage by the program and are initialized and activated at the QDIO adapter, as described below. Each queue consists of multiple separate data structures, called queue components, which collectively describe the queues' characteristics and provide the necessary controls to allow the exchange of data between the program and the adapter.

A Queuing status block is established to reflect the changes dynamically as per the changing I/O activity status. The queues comprise buffers which reflect channel ownership in the channel subsystem, and the ownership also gets updated as the picture dynamically changes. The queue sets are connected via the adapter to the host/main storage. In one preferred embodiment where separate images are provided for virtual systems, each virtual system can also be assigned a separate queue set in the queuing mechanism.

## 25      Exchange of Data

The program and the QDIO adapter use a state change signalling protocol in order to facilitate the exchange of data. This protocol is applied to each input and output data buffer associated with each of the active input and output queues. Both input and output buffers are managed and exchanged between the

program and the adapter by placing the buffer into various states which are maintained in a special location that is set aside and is associated with each buffer. For example for input queues, asynchronous to the execution of the program, the QDIO adapter  
5 places data received from the associated I/O device into input buffers that are in the input buffer empty state. For each input buffer that has data placed into it by the adapter, the state of the buffer is changed from input buffer empty to input buffer primed. The program then examines in sequence (such as round  
10 robin) the state of all input buffers associated with all QDIO input queues and processes the data in each input buffer that is in the input buffer primed state. Upon completion of input buffer processing, the program may change the state of the buffer to input buffer empty in order to make the buffer available for reuse by the adapter for subsequent input data from the attached I/O device. When the program changes the state of one or more input queue buffers from primed to empty, it executes a SIGNAL  
15 ADAPTER instruction which designates the read function in order to signal the adapter that one or more input buffers are now available for use.  
20

Similarly, for output queues, asynchronous to the execution of the QDIO adapter, the program places output data into one or more QDIO output queue buffers that are in the output buffer empty state, output buffer not initialized state, or output  
25 buffer error state and then changes the state of each such buffer to the output buffer primed state. The program executes a Signal Adapter instruction which designates the write function in order to signal the adapter that one or more output queues now have data to be transmitted to the I/O device attached to the adapter.  
30 Asynchronous to the execution of the program, the QDIO adapter transmits the data in each QDIO output buffer that is in the output buffer primed state to the attached I/O device. Upon

completion of transmission, the adapter changes the state of each such buffer to the output buffer empty state in order to make the buffer available for reuse by the program.

Additionally, each data buffer also has an ownership state which identifies either the program or the adapter as the controlling element of the buffer for the period of time that element is responsible for managing and processing the buffer. Additionally, the queuing mechanism provides for a prioritization scheme for the queues. Device addresses are used as queue anchors, retaining I/O heritage to reduce cost.

#### Queue Components

Figure 3 depicts the control structure overview for the input and output queues associated with a QDIO subchannel. Figure 3 also demonstrates the queue components as defined for the present invention. The Queue Information Block (QIB) shown at 310 contains information about the collection of QDIO input and output queues associated with a given subchannel. It provides information for collection of input and output queues for the adapter associated with the subchannel. One QIB is defined per QDIO subchannel; Figure 9 provides the format of queue-information block as per one embodiment of the present invention.

The Storage List Information Block (SLIB) shown at 320 provides for the address of information stored pertaining to each queue. One SLIB is defined for each queue. SLIB contains information about a QDIO queue and has a header and entries called storage-list-information-block entries containing information about each of the buffers for each queue. Figure 10 provides SLIB format as per one embodiment of the present

invention. Furthermore, a storage list information block element or SLIBE can be provided containing information regarding the QDIO data buffer as determined by the corresponding SL entry. Figure 11 depicts a sample SLIBE content.

5       The Storage List or SL shown at 330 defines the SBAL or storage block address lists that are defined for each I/O buffers associated with each queue. One SL is defined for each queue which contains an entry for each QDIO-I/O buffer associated with the queue. SL provides information about the I/O buffer  
10 locations in main storage. As per one embodiment of the present invention, Figure 12 provides a sample SL content. SL also provides the absolute storage address of a storage block address list. In turn, SBAL contains a list of absolute addresses of the storage blocks that collectively make up one of the data buffers associated with each queue as shown at 340. A storage block address list entry or SBALE is also provided as part of each SBAL. Each SBALE contains the absolute storage address of a storage block. Collectively, the storage blocks addressed by all of the entries of a single SBAL constitute one of the many possible QDIO buffers of a QDIO queue. In a preferred embodiment, the number of these possible QDIO buffers equal 128. Figure 13 provides for the format of a SBALE as provided by one embodiment of the present invention. SBALF or SBAL Flags contain information about the overall buffer associated with the SBAL containing each SBALE, and not just about the storage block associated with each SBALE. The description of contents of the SBALF field is different for each SBALE within the SBAL.  
25

30       A Storage-List-State Block or SLSB is shown at 350. The SLSB contains state indicators that provide state information about the QDIO buffers that make up a queue. A QDIO buffer consists of the collection of storage blocks that can be located

using all of the addresses in a single storage-block-address list. Depending on the current state value in an SLSB entry, either the program or the QDIO control unit can change the state of the corresponding QDIO buffer by storing a new value in the 5 entry. Figure 14 provides a sample SLSB format as per one embodiment of the present invention. SLSB also provides for a SQBN or state of queues buffer N which provides the current state of the corresponding QDIO buffer. The QDIO buffer that corresponds to a given SLSB entry is determined by the storage 10 list entry having the same sequential position in the storage list as the SQBN field has in the SLSB. In one embodiment, the state value consists of two parts, bits 0-2 indicate whether the buffer is owned by the program or the QDIO control unit and whether the buffer is an input or output buffer. Bits 3-7 15 contain a value that indicates the current processing state of the buffer. In this embodiment different bits can also be identified to mean different configurations. For example, bit zero can be established to indicates program ownership, while bits 1 and 2 provide for QDIO control unit ownership and buffer type respectively. Bits 3-7 can contain a binary value that indicates the current processing state of the associated buffer such as empty (available for data storage), primed (available to be processed), not initialized (not available for use), or halted 20 (contains valid data but data transfer was prematurely halted by program executing Halt Subchannel), and Error (associated buffer 25 is in an error state and contents of buffer are not meaningful).

Storage Blocks or SBs are storage blocks that are defined collectively to define a single I/O buffer.

The overall process by which QDIO queues are used to 30 exchange data between the program and a QDIO adapter is as follows:

10  
15  
20

5

1) The program constructs one or more input queues and/or output queues in main storage. The maximum number of such queues that a QDIO recognizes depends on the type and model of the adapter. These limits can be used by a CHCS or Store\_Subchannel\_QDIO\_data command.

2) The program transmits the main storage location of each input or output queue to the QDIO adapter by use of an establish\_QDIO\_Queues channel command. To accomplish this, a Start Subchannel command instruction is also executed which designates a QDIO subchannel that is associated with the QDIO adapter.

3) Upon successful completion of the establish\_QDIO\_queues command, the program then activates the queues at the QDIO adapter by executing an activate\_QDIO\_queues channel command. Upon its successful completion, the subchannel is placed into the subchannel-active state and the QDIO-active state. Again a Start Subchannel is used to accomplish this. Alternatively, the active\_QDIO-queues command may be command chained to a previous establish\_QDIO-queues command when Start Subchannel is executed in the previous step.

25

4) Upon activation of the queues, both the program and the adapter can asynchronously transmit data to each other by appropriate use of the queues as long as the designated subchannel, with which the queues are associated, remains in a sub-channel active and QDIO-active state.

5) Any action that causes a QDIO subchannel to exit the subchannel\_active and QDIO-active states causes the QDIO adapter to stop examining and processing all queues associated with the subchannel. This includes: a program initiated action such as

clear or halt subchannel that designates a QDIO subchannel, an  
error condition (including errors within QDIO adapter, the  
channel subsystem or elsewhere in the central processing complex  
that affects the state of a QDIO subchannel) that causes a QDIO-  
5 active subchannel to enter a status pending with alert-status  
state, or a reset/reconfiguration action initiated by the program  
or operator that affects the ability of the QDIO adapter to  
process QDIO subchannels or their queues, such as a deconfigure-  
channel-path command that deconfigures the only available QDIO-  
10 channel path to which a QDIO subchannel is associated.

15 The design of the present invention provides the ability to  
share access to this device across multiple communication stacks,  
multiple priorities and multiple virtual guests and/or multiple  
logical partitions. A new mechanism for mapping various  
resources to queues which are serviced by the microcode is  
devised to facilitate resource allocation and dynamic  
configuration, including single point of definition. This new  
mechanism includes a new control path interface to facilitate  
20 initialization of the configuration parameters and the queue  
structure(s). This includes dynamic expanding of the number of  
queues and queue elements as traffic patterns and feedback  
indicate. The organization of control blocks is critical to  
minimize the amount of data which needs to be translated across  
25 the various software layers, given virtual addressing constraints  
relative to page fixings as required by the I/O.

As the data comes in through the adapter, a buffer is  
assigned to it and in this way, cache pollution is avoided. The  
channel subsystem in this configuration still operates in the  
30 traditional mode for the control flow but in the new manner  
explained above for data flow providing an interrupt free  
outbound traffic. The inbound traffic has to allow for

interrupts. For the inbound traffic, it is not always obvious as when the data arrives exactly and the mechanism allows for selective use of interrupts. In one embodiment there is even an adaptive rate established between the interrupts and the polling rate. Hence, inbound interrupts only take place during low data rates.

### Queue Priority and Sequencing

Both input and output queues are processed by a QDIO adapter in priority sequence as follows:

1) The lowest numbered queue has the highest priority and the highest numbered queue has the lowest priority.

2) For output queues, the adapter processes primed state buffers for the highest priority output queue before processing buffers associated with the next highest priority output queue.

3) For input queues, adapter processing is dependent on the type of QDIO channel path to which it is configured. For adapters configured to OSADe channel paths, the adapter processes incoming data according to the inherent priority of the data, placing the data into empty state buffers of the queue with the associated priority.

4) Depending on the type of QDIO adapter and the model, input queues may have priority over output queues, vice versa, or no defined priority may exist between the two.

25 5) For both input and output queues, each queue is processed in a sequential round robin manner starting with the

buffer associated with SBAL 0, called buffer 0, and continuing until the buffer associated with the last SBAL or buffer, is processed at which point processing starts again with buffer 0.

For input queues, each buffer in the input buffer empty state is sequentially processed until the adapter encounters a buffer that is not in the empty state or no more input data is received. The adapter then processes the non-empty state buffer by looking at whether the input buffer is primed, input buffer not initialized, or input buffer error state is detected. When it sees an adapter in any of these states, the process of scanning the remaining queues entries is suspended until either an interval or time has elapsed, a SIGNAL ADAPTER read function is executed, or additional input from the device or network of devices is detected. This process is continued until the buffer reaches an input buffer empty state at which time it is processed and the adapter resumes the sequential processing of the remaining queues entries. If the Input buffer is in any other state, the adapter terminates the processing of all queues for the associated QDIO subchannel.

For output queues, each output buffer primed state buffer is sequentially processed until the adapter encounters a buffer that is not in the primed state or until a model dependent "fairness" algorithm causes the adapter to process the next lower priority output queue. When an output buffer that is not in the output buffer primed state is detected, the adapter processes the non-primed state buffer as follows. When the output buffer is empty, output buffer is not initialized or is in an error state, the adapter suspends the process of scanning until an interval has passed or a SIGNAL ADAPTER write function is executed. Depending on the model, when one or more of these events occur, the adapter again accesses the SLSB entry for the same I/O buffer that was

previously detected as being in one of these states, the adapter again suspends processing of that queue. If the buffer is now in the output buffer primed state, the buffer is processed and the adapter resumes the sequential processing of the remaining queue entries. If the output buffer is in any other state, the adapter terminates the processing of all queues for the associated QDIO subchannel.

The above configuration provides for interlock data movement avoidance between the queue mechanism where the application can place network data on a queue which can be accessed too easily. The initiative and/or control is passed for the queues between the server software and the microcode as to avoid unnecessary interrupts where ownership of queues is passed back and forth and unnecessary data movements where ownership of data is transferred back and forth under guaranteed interlock to eliminate out of order updates. All updates of both the shared states and queues must be in absolute synchronization. There is also a shared state interface control or SSIC mechanism used to control logical ownership of I/O buffers.

Coupled with these initiatives is a new mechanism for software to interrogate status updates as described below. Previously, this was provided exclusively via interruption. In this way the present invention enables interrogation across queues (multiple priorities) under control of a timer and, as described earlier, in periods of low activity, interrupts are provided and then when activity reaches a certain threshold, control is switched to use the timer.

The interface must be designed to establish a cooperative environment with the Upper Layer Protocols or the ULPs such that the cost to the ULP of executing I/O is minimized. Cost

reduction techniques for both small and large data packets must be designed into the interface. Besides the obvious costs of I/O in terms of instructions per operation, there exists a set of other costs related to but not directly measured against the cost of the current structures. These may be generally described as the price I/O users pay in their own code base to either avoid or minimize the measurable cost of I/O. If one could have a zero impact I/O structure, a ULP would be free to optimize for its environment rather than conform to rules determined by an I/O structure.

In the present invention a new controller area is defined, and during the initialization time, a numeric value is passed to ULP ENABLE which specifies the amount of buffer space needed to build a header required by the adapter, preferably a GigaEnet adapter. A connection manager will then pass this value to all ULP's that wish to utilize the adapter, and during data flows, all datagrams sent will have that amount of storage between the header and the datagram. This methodology removes the need for allocating storage in the data path or adapter header placement which in turn will affect the overall system throughput. In addition the present invention provides for the sharing of network attachment with each ULP owning its own device address.

#### Important Instructions

The present invention provides for several novel instructions and commands that does not exist in the present technology. The first of these is called a Signal Adapter Instruction, hereinafter SIGA instruction. The SIGA instruction comes in several flavors such as a read, a write, and a synchronize SIGA. The command is primarily established to give operational initiative that is missing from the existing systems.

The SIGA instruction works almost like a wake-up call, reminding the system to go and check its queues and process what is pending. It functions as a mid-I/O intrusion instruction that is designated for the checking of the queues. It is an I/O operational signal structure which in case of its synchronization flavor, synchronizes the data in the queues to ensure the state information is pushed out and the queues are processed. It can be initiated by a program timer if desired.

In a preferred embodiment of the present invention, the SIGA comprises an eight bit function code and if called for, a 32 bit parameter is transmitted to the adapter. The following is an example of a SIGA structure.

I. SIGA



Function Code 0 / Initiate Output - When the function code specifies initiate-output, the associated QDIO adapter is signaled to asynchronously process one or more output queues associated with the specified subchannel. In this case, the instruction is referred to as SIGA-w (SIGNAL ADAPTER - write).  
5 The output queues that are to be processed are specified in general register 2.

Function code 1 / Initiate Input - When the function code specifies initiate-input, the associated QDIO adapter is signaled to asynchronously process one or more input queues associated with the specified sub-channel. In this case, the instruction is referred to SIGA-r or Signal Adapter read. The input queues that are to be processed are specified in general register 2.  
10  
15

Function code 2 / Synchronization - When the function code specifies synchronize, the virtual machine is signaled to update the data queues SLSB and SBAL entries in order to render them current as observed by both the program and the QDIO adapter. In this case, the instruction is referred to as SIGA-s or Signal Adapter synchronize.  
20  
25

SIGA-s is required in virtual machine models where QDIO data queue sharing between the program and the adapter is simulated by the use of separate unshared copies of the queues SLSB and SBAL components. One copy of these components is used by the program and one copy is used by the adapter. The execution of SIGA-s signals the virtual machine to update these unshared copies for the data queues as necessary so that both the program and the QDIO adapter observe the same contents for these queues components.

When SIGA-s is specified:

1) The output queues for the designated subchannel that are to be synchronized are specified in general register 2.

5        2) All input queues for the designated subchannel are synchronized.

3) The QDIO adapter is not signaled.

10        4) The virtual machine is signaled if the program is executing in a virtual machine environment. No virtual machine signal is generated when the program is not executing in a virtual machine.

For the SIGA-w and SIGA-r and SIGA-s functions, the second operand ( $B_2D_2$ ) is ignored.

15        When the SIGA-r and SIGA-w or SIGA-s functions are specified, general register 2 specifies a 32 bit parameter that designates which input or output queues are to be processed by the adapter. Bits 0 through 31 correspond one for one with input or output queues 0 through 31 respectively and are called queue indicators QI. Additionally, both input and output queues are prioritized by queue number with the lowest numbered queue (queue 20 0) having the highest priority and the highest numbered queue (queue 31) having the lowest priority.

25        When a queue indicator is one and the corresponding queue is valid, the QDIO adapter is signaled to process the corresponding input or output queues. When a queue indicator is one and the corresponding input or output queue is invalid, the queue indicator is ignored.

A queue is valid when it is established and is active. A queue is invalid when it is not established, is not active, or the model does not allow a queue to be established for the corresponding queue indicator.

5        When the queue indicator is zero, no action is required to be taken at the adapter for the corresponding queues. When all queues indicators in general register 2 are zero, the adapter is not signaled and no other operation is performed.

10      Subsequent to the execution of SIGA, the QDIO adapter associated with the designated subchannel performs the specified function. When the SIGA-w function is specified, the adapter processes each specified output queue in priority sequence. For each queue that contains queue-buffers in the primed state, the data in the buffers is transmitted and upon completion of transmission, the queue buffers are placed into the empty state. This process continues until the data in all primed output queue buffers, for all specified output queues, has been transmitted.

15      20      When the SIGA-r function is specified, the adapter processes each specified input queue in priority sequence. For each queue that contains queue-buffers in the input buffer empty state, data is placed into the queue buffers as it is received and upon completion of the transmission, the queue buffers are placed into the input buffer primed state. This process continues for each empty queue buffer in sequence until a buffer that is not in the input buffer empty state is reached. This process is then repeated for the next lower priority input queue. If any queue buffers for all specified input queues have been filled with data.

## Shared State Interface Control

Another important aspect of the present invention is its ability to share state interface. The Shared State Interface Control or SSIC function that provides shared state interface between the QDIO adapter and a QDIO program, such as a multipath channel program, can best be described in the following diagram:

### WRITE

| QDIO Program | State | QDIO Adapter |
|--------------|-------|--------------|
|--------------|-------|--------------|

Fill 'n' SBAL's with data ---> primed  
set state to multiple  
SBAL's may be processed  
Issue SIGA to drive the  
adapter

Process all outbound data  
empty <----- set state to

Program frees 'empty'  
write buffers after SIGA

'last ditch' timer will free  
any lingering buffers

READ

| QDIO Program | State | QDIO Adapter |
|--------------|-------|--------------|
|--------------|-------|--------------|

If required, replace used  
buffers for multiple SBALEs  
5 within each SBAL  
set state to -----> empty

10 Fill inbound buffers  
for each SBAL used  
primed <-----set state to  
low traffic - new PCI  
else nothing

15 Drain data and pass to ULP,  
Replace all used buffers  
set state to ----->empty

II. Store Subchannel QDIO Data or CHSC Command

20 Input/output operations for QDIO involve the use of an I/O device represented by a subchannel in the channel subsystem. The proper execution of QDIO I/O operations depends on certain characteristics of the subchannel. Examples of such characteristics are:

- o whether the subchannel supports QDIO operations
- o the format of the queues
- o the number of input and output queues
- o I/O-device requirements regarding program issuing of the SIGA instruction.

The store-subchannel-QDIO-data command provides the program with a way to determine from the channel subsystem the QDIO characteristics (listed above) that the program must take into account in order to perform I/O operations using a specified 5 subchannel. Previous mechanisms that allow programs to determine operational characteristics of I/O devices normally consist of the program executing a channel program to obtain such information from the I/O device.

By providing the store-subchannel-QDIO-data command, it is 10 possible for I/O devices to have different QDIO characteristics and for the program to determine what those characteristics are prior to communicating with the I/O device itself.

The CHSC command is used to obtain self description 15 information for the QDIO adapters associated with a specified range of subchannels. When the CPC is operating in a mode where several images are used, the CHSC command is used to obtain self description information for the QDIO adapters associated with a specified range of subchannel images, configured to the logical partition that executed the command information for subchannel 20 images configured to other logical partitions, if any, is not provided. Figure 5A represents the format for the command request block for store-subchannel-QDIO data. Figure 5B represents the format for the command response block for the store-subchannel-QDIO data command. In addition, Figure 6 25 represents the format for Subchannel-QDIO description Block.

In short the CHSC command specifies which device the request 30 for processing can be sent to. It further provides for the format and attributes of the QDIO, such as the size and attribute of the queues, and other characteristics that may relate to the specific processor. QFMT or QDIO Queues Format and QDIOAC or

QDIO Adapter characteristics in the above figures represent this information. IQCNT provides the Input Queues Count and OQCNT provides an Output Queue Count.

### III. QDIO Priority Instructions

5       The user can issue a request leading to a SETUP\_REQ instruction. When processing this instruction a device address will be assigned to the user which will be passed along via a SETUP SDU instruction. The SETUP primitive will also pass priority queue information to the adapter. The format of this is shown in Figure 4. Length is defined by Length of DIF including this field. Category is defined as the value of primitive specific. Type denotes the value of data path device address. DEV\_CUA is a multi-digit CUA in packed format. DEV\_NO. refers to the device number assigned to this ULP's connection. Priority Service Order is the order by which the adapter will service the queues. It is used to provide a favorable service for higher priority vs. lower priority queues. Maximum Service Limit Units refer to the units that are used under a favored treatment based on the amount of outbound data allowed to be processed during one processing interval. It can be defined in three flavors: maximum number of packets to be transmitted - counts packet size without regard to packet size; maximum number of bytes allowed to be transmitted; and maximum number of SBALs that may be transmitted - without regard to number of packets or amount of data within the SBAL. Maximum Service Unit Priority provides the number of units on a priority basis.

#### Data Packing

     Data packing is another important feature that is affected by the present invention. As the cost of I/O decreases, the need

to prorate traffic to reduce the cost per data element decreases. However, the need still exists and the present design will allow for a multi-path channel or MPC to perform data packing through the device driver code which "unpacks" packed data received from the ULPs directly into a Storage\_Block\_Address\_List array so that packed format data is not handled directly. This approach is taken because packed data resides in slower memory than the Storage\_Block\_Address\_Lists array provides. In addition, data packing for small objects is supported and non-contiguous headers for large objects is supported within a single data queue. In this context a non-contiguous header implies the use of a single entry for a network or control headers. A preferred ULP to be supported is TCP/IP which will build upon existing packing algorithms to reduce cost of I/O by continuing to pro-rate the cost across multiple datagrams. When an MPC is used, the device driver code will unpack the datagrams into the Storage\_Block\_Address\_List arrays. To provide for the efficient flow of large data objects, unpacked datagrams will also be supported but the criteria upon whether a given flow is to be packed or not depends upon the size of the packet. To further optimize the system when TCP/IP is used, TCP/IP will include a controller work area, preferably a 32 byte header, and the start of the datagram for all data transfers. In all cases the controller area, if specified, must be provided by the ULP as part of any network or control header. This includes single datagram transfers where network headers, any control header, any defined data header and the user data have been moved to form a continuous bit stream. Headers must also be supplied when non-continuous header datagrams are used. MPC will not insert the header on behalf of the ULP. Note that an SBALE or a Storage\_Block\_Address\_List\_Element is also defined, preferably with a 4k page limit to allow attachment of the Queued Direct I/O to different switches such as fiber optic switches and International Business Machine's ESCON

switch (ESCON is a registered trademark of IBM Corp. of Armonk).

5

Another problem that severely impacts current systems is the lack of an efficient gather/scatter function. Since data chaining is exposed to the remote partner, it is no longer efficient for network communications. Yet data movements within the server continue to be major performance inhibitors for mid-size or large data objects. This problem is resolved by inventing an out-of-band header(s) such that the user data need not be moved or copied in construction of the data stream.

10

15

The problems with system dispatching is also minimized by establishing a common user interface such that the user can assist in dispatch control. When an MPC is used, the MPC will establish a Direct Queue Area or a DQA for each ULP exploiting the network attachment. This area will be used to control the queuing of inbound data as well as provide the control structure to be used for dispatching options and processing.

20

25

30

The present invention has enhanced the existing system support for high performance applications that wish to take advantage of high speed media attach. Intent is to minimize inbound dispatching by providing a set of optional mechanisms that bypass the traditional SRB dispatch from disabled code that occurs during current I/O disabled completion. Since there is no change of ownership required for such protocols such as TCP/IP, the recovery procedure will no longer be needed in many instances. Also, no assigned buffers (ASSIGN BUFFER) are required for inbound traffic (TCP/IP). The data will not be blocked by the MPC or multipath channel and the interface layer will perform the deblocking function itself. Since MPC is not deblocking into smaller datagrams, there is no need for an assign buffer. The operation is driven by a disable timer during mid-

high traffic rates, and all inbound queues for all interfaces will be processed via the timer mechanism, and fast interrupt indicators will be set off for all read data paths. This in turn will eliminate the need for some inbound dispatching functions  
5 like the use of MPC supplied Direct Queue Area. The ULP will include a user area for specific processing and the SBAL format will include the addresses and lengths of input data. A new function, IUTIL CM\_ACT is also provided that will contain fast dispatching (FAST DISPATCH) which in turn will allow the ULP to  
10 optimize its own environment.

### Dynamic Configuration

In the existing systems, all Gateway-types of attachments need to have a configuration file defined which identifies various items. These items include the following:

1) Host Device Address - this definition is needed to define the Host Number and Host Unit address, especially when multiple or virtual images/machines are being used when passing data across any channel interface. This information is needed by the channel subsystem to determine which Host connection is to receive the incoming data. It is also needed for each Host or Host Unit Address which is to be used to transfer data across the channel interface to an adapter.

2) Host Application - This identifies which Host Application is using the Host device Address.

25 3) Application Specific Address - This address is used to identify the specific Application Server to which the inbound data received from the LAN is to be routed. Each Application Specific Address is directly related to the Host Device Address

and Host Application.

4) LAN Port Number - this identifies which LAN Port is to be used for sending data which is received at the Gateway from the Host Device Address.

5           5) Default Routes - these are defined on a Host Application basis. Each Host Application can have a default Host Device Address specified. This Host Device Address is used to send all traffic received from the LAN for a specific Host Application for which an Application Specific Address has not been defined. For example, if a TCP/IP packet is received from the LAN and the TCP/IP address found in the packet was not defined in the configuration file, this packet would be sent to the Host over the Host Device Address defined by the Default Route entry.

10           6) Setting Thresholds for Priority Traffic - this defines the percentages of processing which should be used on the various priority traffic. For example, this command could be used to define the maximum number of bytes which should be processed for a specific priority before moving on the check for work for a different priority.

15           The present invention changes all that. All configuration information defined above is no longer needed in the configuration file. In fact, the configuration file is no longer required on the Gateway attachment using the QDIO Interface. All the information is presented to the Gateway device at initialization time through various tables and commands which are passed over the channel interface.

A table is provided which maps all the Host images and Host Device Addresses which will be using the QDIO Interface to the specific bits defined in the SIGA vector. This list is derived directly from the information defined in the IOCDS on the Host.

5      Each entry in the IOCDS which defined an ADIO device causes an entry to be placed in the initial table. At initialization time, each entry in the table is assigned a specific bit in the SIGA vector. Also, at any time after initialization, this information can be dynamically changed and Host Device addresses can be added

10     and/or deleted.

The Host Application which is to use the Host Device Address is defined using a command called MPC\_ENABLE-IC Command. The Application Specific Address is defined using the SETIP command. The Application Specific Address can also be deleted using the DELIP command. The LAN Port Number is specified in the STRTLAN Control Command. The Default Routes are defined using the SETRTG Control Command. This is a new control command defined specifically in the present invention. Setting thresholds for priority traffic is defined using the SETPRIORITYTHRESHOLD Control command which defines the maximum number of bytes which can be processed for a specific QDIO Priority QUEUE before checking for work on the other QDIO Priority QUEUES. This command allows the user to tailor each individual system for its specific application requirements.

25     Using this and the queue priority instructions the specific algorithm which is to be used when servicing each of the different priority queues is addressed. Each Host Device has the ability to set its own unique priority algorithm.

## SIGA Vector Implementation

The SIGA Vector is needed to give initiative to the QDIO connected Gateway device. One problem which is solved by the present invention is the use of Priority Queues and how a priority algorithm which needed to serve multiple priority queues at the specified priority values. In other words, certain queues represented by the SIGA Vector needed to be completely serviced on each invocation because they were the highest priorities.

Each queue at the next lowest priority needed to have the ability to have some of its traffic left pending if its thresholds for service were reached. The higher priority queues then needed to be rechecked if more work had come active while the lower priority queues still had work pending.

To accomplish the above task, the SIGA Vector is split into a priority bit mask. Each Device Address which was assigned to the QDIO interface had one queue assigned for each of the possible priorities. In one embodiment of the present invention, there are four bits assigned to each of the different Device Addresses. When a certain priority work request needs to be sent, the bit corresponding to the Device Address and its corresponding priority is set. As requests come in from different priorities or from different Device Addresses, their bits would also be set. This gives the Host System the ability to filter multiple different work requests in the same SIGA Mask.

Another problem addressed is the effective service of various QDIO priorities when only a single bit is being used to signal the Gateway device work. Since it is possible that all the work for a certain priority would not be serviced before checking back for more work for the other priorities, the Gateway device needed to be able to remember the current work, but be

able to go back and look for more new work. To do this, the  
Gateway device would write a specific value into the SIGA Vector  
area after each read of the vector. Once the Host code detected  
the value written by the Gateway device, the vector would be  
5 completely cleared and then new work requests were added.

Clearing of the vector after each read enables the fairness  
algorithms so the different priorities could be processed at  
their desired rates.

One additional problem to be addressed is the number of bits  
10 which is needed to be scanned to identify the work requests. In  
one embodiment of the present invention, there are a possibility  
of 240 Device Addresses. Each Device Address has 4 priorities,  
so this computes to  $4 * 240$  or 960 possible bit settings. The  
overhead of scanning all these bits to find the work requests is  
too high. To make the searching faster, the 960 bits are split  
15 into 30 different 32-bit masks. When a new work request is  
added, the bit in one of the 30 different 32-bit masks is set.  
Also, the bit in the Work Vector which corresponds to the 32-bit  
mask in which the bit was set is also set.

20 The work vector which identified the specific 32-bit mask  
made finding the bits which were set much more efficient. The  
Gateway device can now scan the Work Vector to find the  
appropriate 32-bit mask. The Gateway device can then just fetch  
the proper 32-bit mask to find the work request.

25 In one embodiment of the present invention, all high  
priority traffic is handled completely and then the amount of  
data processed from the other queues is assigned a weight using  
the SETPRIORITYTHRESHOLD command. Once the lower priority queues  
30 have been handled, it is possible some data could be residual in  
these queues. It then becomes necessary to go back and check the

5

priority queues if new requests have arrived. To make sure only new requests have been added to the List when it is refetched, each time the adapter reads the SIGA Vector, it sets a field to indicate the vector has been read. The next Host request will then see the adapter has read the SIGA Vector. It is then completely cleared by the Host code before setting the new request.

10

15

20

25

#### Error Reporting During Run Time - Non Catastrophic

As data is being transferred across the QDIO interface to and from the Gateway device, it is possible for errors to periodically occur in the data stream. Intermittent errors can be recovered. Errors which become persistent need to be detected so the interface can be taken down and then restarted. All this needs to happen at run time and require no user interventions.

To accomplish this, Error States are defined for the SLSB Status Block. When the adapter detects errors in the data stream, an error state is set in the SLSB. The specific reason for the error is stored in the SBALF (SBAL Flags) which are located in the SBAL which is associated with the SLSB that has the error state set. Using this approach, the Host is able to monitor the number of errors which occur within a specified time period. If the number of errors exceeds the pre-determined threshold which has been set, the QDIO Connection is terminated. If the error rate stays under the specific threshold, the connection will remain active.

#### Concurrent Patch

Concurrent Patch is a feature provided in QDIO. The Concurrent Patch feature allows the customer to install a new

level of microcode to the adapter without interrupting any of the applications and/or services using the adapter. For Channel adapters this was not a major problem because all of the applications using the channel adapter did not require any connection-type of information to be kept across the code update.

For the Network Adapters which are using TCP/IP, the adapter contains information about each client station in the LAN and each connection which is present with the Host Applications. The connections are active once the adapter is activated and remain present while the card is active. There are no Gateway platforms today which will keep the TCP/IP sessions active during a code update. The QDIO Hydranet adapter is the first to offer the Concurrent Patch feature in a Gateway environment.

#### QDIO in Virtual-Machine Environment

The key control mechanism for QDIO is the storage-list-state block (SLSB), comprising a vector of state entries for each queue, with one entry per storage-block-address list (SBAL). An SBAL contains the addresses of a set of storage blocks within main memory, the collection of which is termed a buffer, either input or output.

Each SLSB entry represents a finite-state machine (FSM), an automaton well known in the art, defining the states of a computing process, the inputs and outputs of the process for each state, and the allowed transitions among the states. Whereas a standard FSM is executed by a single process, the FSM in an SLSB entry in this invention is shared and used as a control and communication mechanism by a host program on the one hand and by an I/O adapter on the other. The FSM is used by each to drive the other. The set of states of the FSM is strictly divided into

two subsets, program-owned states and adapter-owned states. The ownership is indicated by bits within the encodings of the state-values. Each side exchanges ownership with the other to cause control and processing to pass between them.

5        Thus, the FSM of an SLSB entry embodies two sets (one each in the program and the adapter) of one or more processes under the control of the FSM definition. These sets of processes are kept separate and carefully controlled through the two distinct subsets of FSM states, implying ownership by one side or the other, as described above. However, within either side (program or adapter), multiple processes may share and be controlled by the FSM. Such sharing processes within a given side may use the state-values within its own side's ownership subset to control and communicate with other processes on its own side, but not the other side. That is, neither side is permitted to understand or act upon the meaning of a specific state-value that is owned by the opposite side, other than to transfer ownership according to the FSM definition. This strict separation of the program and the adapter within the FSM ensures that each side can be a free-running process (or set of processes) through the entire set of FSMs in an SLSB without the possibility of deadlock.

10      Within the preferred implementation, there are separate FSM definitions for input and output queues. The five FSM states for input queues are as follows:

- 15      \* input buffer not initialized (program owned)  
\* input buffer empty (adapter owned)  
\* input buffer primed (program owned)  
\* input buffer error (program owned)  
\* input buffer halted (program owned)

The five FSM states for output queues in the preferred implementation are as follows:

- \* output buffer not initialized (program owned)
- \* output buffer empty (program owned)
- \* output buffer primed (adapter owned)
- \* output buffer error (program owned)
- \* output buffer halted (program owned)

Figures 7 and 8 depict sample Input and Output queues as relating to this particular area as will be discussed below. With the FSM in each SLSB entry being executed cooperatively but independently by the program and the adapter, the processing of an entire input or output queue is accomplished by sequentially cycling through the full set of FSMs (and, hence, buffers) within the SLSB controlling the queue.

The following control mechanisms is an abstract, simplified version of the preferred implementation for the proper sequencing through the buffers.

#### Output Queues:

Program

-----

```
Current_Entry = 1;
LOOP: DO WHILE Current_State = ^PRIMED AND output data exists;
      Execute FSM for Current_Entry;
      Current_Entry = Current_Entry + 1 modulo SLSB_Size;
END;
WAIT (for more data from application or Current_State
change);
GO TO LOOP;
```

Adapter

```
-----  
      Current_Entry = 1;  
      LOOP: DO WHILE Current_State = PRIMED;  
             Execute FSM for Current_Entry;  
             Current_Entry = Current_Entry + 1 modulo SLSB_Size;  
             END;  
             WAIT (for SIGA-w signal);  
             GO TO LOOP;
```

10 Input Queues:

Program

```
-----  
      Current_Entry = 1;  
      LOOP: DO WHILE Current_State = ^EMPTY;  
             Execute FSM for Current_Entry;  
             Current_Entry = Current_Entry + 1 modulo SLSB_Size;  
             END;  
             WAIT (for PCI or timer interruption);  
             GO TO LOOP;
```

20 Adapter

```
-----  
      Current_Entry = 1;  
      LOOP: DO WHILE Current_State = EMPTY AND input data exists;  
             Execute FSM for Current_Entry;  
             Current_Entry = Current_Entry + 1 modulo SLSB_Size;  
             END;  
             WAIT (for more data, SIGA-r signal, or Current_State  
                   change);  
             GO TO LOOP;
```

These control mechanisms (i.e., the FSMs and the sequencing logic to loop through the FSMs in an SLSB) keep the program and the adapter in synchronism with each other without deadlock as the cooperating processes on each side move in tandem through different portions of the SLSB. The invariant conditions are that each side always processes FSM states not processed by the other, and as data is moved inbound or outbound, each side sets FSM states processed by the other. As long as one side is running, it sets states that will be processed by the other side, and vice versa.

The QDIO protocol so far described is extended in the present invention to be used in a virtual-machine environment through minor additions along with careful design and attention to the following considerations.

A key aspect of QDIO is the shared-memory model by which the program and the adapter share a common queue structure and data areas in a computer's main memory. With the free-running cooperative processes described above, controlled by a set of FSMs in an SLSB for each data queue, the use of shared memory avoids the processor and channel-subsystem overhead of start-processing and one-for-one interruptions associated with traditional input/output operations.

Such a shared-memory model is problematic in the environment of a virtual machine, which is an image of a real machine created by a program called a virtual-machine hypervisor. The apparent real storage of the virtual machine is in fact pageable storage of the hypervisor. The adapter, lacking dynamic-address-translation (DAT) capability and the hypervisor's associated DAT tables, needs to know the actual real-storage addresses of the queue structures and data.

The shared-memory model of the QDIO protocol is simulated by the virtual-machine hypervisor through the use of "shadow" copies of key control blocks that are maintained by the hypervisor. The QDIO control-block structure is designed in such a way as to  
5 carefully separate and isolate main-memory addresses from non-address information.

Among the QDIO control blocks, the storage list (SL) and storage-block-address list (SBAL) are designed specifically to contain addresses needed by the adapter. The queue-information block (QIB) and the storage-list-information block (SLIB) are designed specifically to exclude any such addresses. The memory pages containing the QIB and the SLIB are fixed in main memory by the hypervisor and, thus, follow the QDIO shared-memory model: the program accesses the QIB and the SLIB using addresses that are in fact virtual, while the adapter accesses these same control blocks with real addresses.  
10  
15

The SLs and SBALs are shadowed by the hypervisor. The SLSB is also shadowed, although it contains no addresses, because of its definition as the controlling mechanism for the program's and the adapter's cooperating processes. The changing of FSM states in the SLSB controls the program's and the adapter's access to the other queue components that require address translation, and hence, FSM state-changes must be gated and controlled by the hypervisor using the shadow-block mechanism.  
20

The QDIO protocol is started by the existing START SUBCHANNEL (SSCH) machine instruction in the preferred implementation, but could be started by one or more new instructions defined for the purpose. For pageable virtual machines, SSCH is intercepted by the hypervisor so as  
25 to begin the simulation of the QDIO protocol. During the

simulation of the Establish-QDIO-Queues channel command, the  
hypervisor builds shadow copies of the SL, SBAL, and SLSB control  
blocks. The queue-descriptor record (QDR) associated with the  
Establish-QDIO-Queues command contains the main-memory addresses  
5 of the QDIO queue components as seen by the program. The  
hypervisor translates those addresses, as well as addresses  
within the SL and SBALs, in building its own copy of the QDR  
and the shadow SL and SBALs. Translation of addresses within the  
SBALs may be delayed until the simulation of the Activate-QDIO-  
10 Queues channel command if the program chooses to defer its data-  
buffer assignments until the queues are activated.

Once the QDIO protocol is started, the virtual-machine  
hypervisor needs to intervene to perform address translation  
whenever the program presents a new set of empty or full buffers  
to the adapter for inbound or outbound data, respectively. The  
hypervisor also intervenes when synchronization is needed between  
the program's original SLSB and the hypervisor's shadow SLSB used  
by the adapter. Such address translation and SLSB  
synchronization is implicit during the hypervisor's  
interception of program-controlled interruptions (PCIs) and the  
SIGA-w and SIGA-r instructions. The SIGA-s instruction causes  
hypervisor intervention when there is no signal needed between  
the program and the adapter in the non-virtual-machine  
environment, but there is nevertheless a need for address  
25 translation and SLSB synchronization for the virtual machine. In  
the preferred implementation, SIGA-s is used by the program when  
recovering emptied outbound buffers from the adapter and after a  
program timer expires to signal the need for checking of SLSB  
states on input queues.

30 The previously-described FSM definitions and sequencing  
protocols for the SLSB support and make possible the operation of

QDIO in virtual machines. The concept of ownership of SBALs and data buffers, as embodied in the separate program-owned and adapter-owned states of the FSMs, means that the adapter never accesses main memory for which the adapter does not have ownership within the applicable FSM. Ownership is only transferred from program to adapter by the setting of an adapter-owned state in the FSM by the program and the subsequent synchronization of the program's FSM with the adapter's shadow FSM by the hypervisor, after the hypervisor performs the necessary address translation. Likewise, ownership is only transferred from adapter to program by the setting of a program-owned state in the FSM by the adapter and the subsequent synchronization of the real and shadow FSMs, after the hypervisor updates the applicable real SBALs from the shadow SBALs with, for example, the actual data count moved through the adapter.

The mutually-exclusive FSM-state subsets between the program and the adapter, with the rule of each side setting ownership by the other side to transfer processing between them, enables straight forward synchronization of the real and shadow SLSBs by the hypervisor. The hypervisor maintains a "hidden shadow" copy of the SLSB to reflect the state of the SLSB at the previous synchronization point. This permits easy recognition of changes made by the program to the real SLSB and by the adapter to the shadow SLSB, allowing the proper updates in each direction between the real and shadow SLSBs with one pass through the three copies of the SLSB at each synchronization point.

The mutually-exclusive FSM-state subsets and the sequencing rules through the SLSB entries further support virtualization by ensuring that synchronization by the hypervisor does not disrupt or interfere with concurrent operations by the program and the adapter on their respective copies of the SLSB. The boundaries

between program-owned and adapter-owned states constantly move downward through the SLSB and back to the top. Neither side looks beyond its own contiguous set(s) of owned FSMs, with the boundaries being apparent. This means the method of  
5 synchronization by the hypervisor, whether top-down, bottom-up, or middle-to-middle in either direction, can have no lasting effect of disrupting the program's or the adapter's operation.

While the invention has been described in detail herein in accordance with certain preferred embodiments thereof, many modifications and changes therein may be effected by those skilled in the art. Accordingly, it is intended by the appended claims to cover all such modifications and changes as fall within the true spirit and scope of the invention.  
1.0

What is claimed is:

1        1. In a network computing system, an apparatus for providing  
2           direct processing access between a application servers and  
3           application users comprising:

4                a main storage capable of establishing processing  
5           communication with an application server;

6                said main storage containing a queuing mechanism for  
7           retrieval and storage of incoming and outgoing data without  
8           causing interrupts in any running programs;

9                an interface element capable of establishing processing  
10          communication with at least one application user;

11          an interrogator for examining multiple queues in said  
12          queue mechanism to transfer appropriate requests, responses and  
13          data between said application server(s) and said application  
14          user(s).

1        2. The apparatus of claim 1, wherein said Interface Element  
2           further comprises of a Connector Interface Element and a Network  
3           Interface Element.

1        3. The apparatus of claim 2, wherein said Connector  
2           Interface Element is in processing communication with said main  
3           storage via a Self-Timed Interface or an STI bus.

1        4. The apparatus of claim 2, wherein said Connector  
2           Interface Element comprises a plurality of processors.

1       5. The apparatus of claim 4, wherein one of said plurality  
2 of processors is used for redundancy purposes.

1       6. The apparatus of claim 2, wherein said main storage can  
2 be in processing communication with a plurality of network  
3 elements and servers.

1       7. The apparatus of claim 6, wherein said plurality of  
2 networks comprise at least a web-servers.

1       8. The apparatus of claim 7, wherein said web-server is a  
2 TCP/IP oriented server.

1       9. The apparatus of claim 2, wherein said Connector and  
2 said Network Interface Elements are in processing communication  
3 with one another via a Peripheral Controller Interface bus or a  
4 PCI bus.

1       10. The apparatus of claim 2, wherein said Network  
2 Interface Element further comprises an I/O device adapters, at  
3 least one more processor and a local storage area.

1       11. The apparatus of claim 10, wherein said Network  
2 Interface Element is capable of connecting to one or more  
3 individual application users.

1       12. The apparatus of claim 1, wherein said Interface Element  
2 performs only a few special functions that replace multitudes of  
3 channel functions normally performed by said computing network  
4 environment.

1           13. The apparatus of claim 1, wherein said Interface  
2 Element performs special functions that replace many functions  
3 normally performed by one or more control units.

1           14. In a network computing system having a main storage  
2 capable of connecting to at least one application server and an  
3 interface element with at least one adapter capable of  
4 establishing processing communication with at least one  
5 application user(s), an apparatus for providing direct processing  
6 access between said main storage and said adapter comprising:

7                 data receivers set up in said application server for  
8 processing data;

9                 a plurality of queues located in main storage for  
10 providing continuous running of programs without interruptions;

11                 an updatator for changing the status of said network  
12 computing system every time new data is received, deleted or  
13 modified;

14                 an interrogator for interrogating multiple existing  
15 queues in said main storage simultaneously to process any  
16 received data or requests;

17                 a determinator for interrogation and routing of data to  
18 appropriate application user to which said data has to be  
19 forwarded to.

1           15. The apparatus of claim 14, wherein said Interface  
2 Element further comprises of a Connector Interface Element and a  
3 Network Interface Element.

1        16. The apparatus of claim 15, wherein said Connector  
2        Interface Element is in processing communication with said main  
3        storage via a Self-Timed Interface or an STI bus.

1        17. The apparatus of claim 15, wherein said main storage can  
2        be in processing communication with a plurality of network  
3        elements and servers.

1        18. The apparatus of claim 15, wherein said Connector and  
2        said Network Interface Elements are in processing communication  
3        with one another via a Peripheral Controller Interface bus or a  
PCI bus.

1        19. The apparatus of claim 15, wherein said Network  
2        Interface Element further comprises an I/O device adapters, at  
least one more processor and a local storage area.

1        20. The apparatus of claim 19, wherein said Network  
2        Interface Element is capable of connecting to one or more  
individual application users.

1        21. The apparatus of claim 15, wherein said Connector  
2        Interface Element is in processing communication with said main  
3        storage via a direct access memory I/O device.

1        22. The apparatus of claim 15, wherein said Connector and  
2        said Network Interface Elements are in processing communication  
with one another via a direct access memory I/O device.

Abstract of the Disclosure

AN APPARATUS FOR PROVIDING DIRECT DATA PROCESSING  
ACCESS USING A QUEUED DIRECT INPUT-OUTPUT DEVICE

An apparatus for providing direct data processing access in  
5 a network computing system environment. The system environment  
has a main storage which can be connected to one or more  
application servers and is in processing communication with an  
interface element. The interface element has at least one  
adapter and can be connected to one or more application user(s).  
10 One or more queues are established in the main storage that can  
handle data without causing interrupts in the running programs.  
Incoming data is received using the adapter and as data is  
received or modified, the status of the network computing system  
will be updated to reflect the new data or change. Data is then  
15 processed in the main storage after interrogating the multiple  
existing queues in the main storage simultaneously and forwarding  
them in turn to their appropriate destination or application  
server after a determination has been made by interrogating these  
queues.



FIGURE 1



**FIGURE 2A**

109-99-014  
Page 2 of 11



# FIGURE 2B





Figure 3

P09-99-014

Page 4 of 11

| Offset | Length | Function                         |
|--------|--------|----------------------------------|
| 0      | 2      | Length                           |
| 2      | 1      | Category                         |
| 3      | 1      | Type                             |
| 4      | 2      | Dev_CUA                          |
| 6      | 2      | Dev_No                           |
| 8      | 1      | Priority service order           |
| 9      | 1      | Maximum service limit units      |
| 10     | 2      | Reserved                         |
| 12     | 4      | Maximum service units priority 1 |
| 16     | 4      | Maximum service units priority 2 |
| 20     | 4      | Maximum service units priority 3 |
| 24     | 4      | Maximum service units priority 4 |

Figure 4. New device address SETUP SDU field

P09-99-014

Page 5 of 11

P09-99-014

Page 6 of 11

**Request Block** The command-request block for store-subchannel-QDIO data has this format:

|        |                                     |                  |
|--------|-------------------------------------|------------------|
| Word 0 | '0010'                              | '0024'           |
| 1      | 00000000 00000000                   | First SCH Number |
| 2      | 00000000 00000000                   | Last SCH Number  |
| 3      | 00000000 00000000 00000000 00000000 |                  |

0

16

31

Figure 5. Format of Command-Request Block for Store-Subchannel-QDIO Data.

**Response Block** The command-response block for the store-subchannel-QDIO-data command has this format:

|        |         |                            |
|--------|---------|----------------------------|
| Word 0 | L2      | Response Code              |
| 1      | C Rsvd. | 00000000 00000000 00000000 |
| 2      |         | Subchannel                 |
|        | //      | QDIO                       |
|        |         | Description Block          |
| 10     | //      | //                         |
| n      | //      | //                         |

0

1

8

16

31

Figure 6. Format of Command-Response Block for Store-Subchannel-QDIO Data.

The subchannel-QDIO-description block has this format:

P09-99-014  
page 7 of 11



Figure 10. Storage-List-Information Block (SLIB)



Figure 12. Storage List



Figure 11. Storage-List-Information-Block Entry (SLIBE)

P09-99-0.14  
Page 8 of 11

|            |                           |      |          |  |  |
|------------|---------------------------|------|----------|--|--|
| 0          | QFMT                      | PFMT | Reserved |  |  |
| 1 Reserved |                           |      |          |  |  |
| 2 Reserved |                           |      |          |  |  |
| 3 0        | First Input SLIB Address  |      |          |  |  |
| 4 Reserved |                           |      |          |  |  |
| 5 0        | First Output SLIB Address |      |          |  |  |
| 6 Reserved |                           |      |          |  |  |
| 7          |                           |      |          |  |  |
| 8          | Adapter Identifier        |      |          |  |  |
| 9          |                           |      |          |  |  |
| 10         | Reserved                  |      |          |  |  |
| 31         | // Reserved //            |      |          |  |  |
| 32         | Implementation            |      |          |  |  |
| 63         | Dependent Parameters //   |      |          |  |  |

Figure 9. Queue-Information Block (QIB)

P09-99-014

Page 9 of 11

| Word | 0                                   | '0010'            | '0024' |
|------|-------------------------------------|-------------------|--------|
| 1    | 00000000 00000000                   | First SCII Number |        |
| 2    | 00000000 00000000                   | Last SCII Number  |        |
| 3    | 00000000 00000000 00000000 00000000 |                   |        |

0

16

31

Figure 5 Format of Command-Request Block for Store-Subchannel-QDIO Data.

**Response Block** The command-response block for the store-subchannel-QDIO-data command has this format:



Figure 6 Format of Command-Response Block for Store-Subchannel-QDIO Data.

The subchannel-QDIO-description block has this format:

Input Queues

| Current State                                       | Actions                                                                       | New State                                           |
|-----------------------------------------------------|-------------------------------------------------------------------------------|-----------------------------------------------------|
| Input Buffer Not Initial.<br>Buffer Owner: Program. | By the Program:<br>Allocate buffer.                                           | Input Buffer Empty.<br>Buffer Owner: Adapter.       |
| Input Buffer Empty.<br>Buffer Owner: Adapter.       | By the Adapter:<br>Fill buffer with data.                                     | Input Buffer Primed.<br>Buffer Owner: Program.      |
| Input Buffer Empty.<br>Buffer Owner: Adapter.       | By the Adapter:<br>Fill buffer with data.<br>HALT signal terminates transfer. | Input Buffer Halted.<br>Buffer Owner: Program.      |
| Input Buffer Empty.<br>Buffer Owner: Adapter.       | By the Adapter:<br>Error detected during buffer processing.                   | Input Buffer Error.<br>Buffer Owner: Program.       |
| Input Buffer Primed.<br>Buffer Owner: Program.      | By the Program:<br>Process buffer data.                                       | Input Buffer Empty.<br>Buffer Owner: Adapter.       |
| Input Buffer Primed.<br>Buffer Owner: Program.      | By the Program:<br>Process buffer.                                            | Input Buffer Not Initial.<br>Buffer Owner: Program. |
| Input Buffer Halted.<br>Buffer Owner: Program.      | By the Program:<br>Application dependent.                                     | Not Appl.. Q processing is terminated by HSCH       |
| Input Buffer Error.<br>Buffer Owner: Program.       | By the Program:<br>Reclaim or replace buffer.                                 | Input Buffer Empty.<br>Buffer Owner: Adapter.       |

Figure 7 Allowed QDIO Input Queue Buffer State Transitions.

P09-99-014  
Page 10 of 11

Output Queues

| Current State                                        | Actions                                                                          | New State                                       |
|------------------------------------------------------|----------------------------------------------------------------------------------|-------------------------------------------------|
| Output Buffer Not Initial.<br>Buffer Owner: Program. | By the Program:<br>Allocate and fill buffer.                                     | Output Buffer Primed.<br>Buffer Owner: Adapter. |
| Output Buffer Empty<br>Buffer Owner: Program.        | By the Program:<br>Fill buffer with data.                                        | Output Buffer Primed.<br>Buffer Owner: Adapter. |
| Output Buffer Primed<br>Buffer Owner: Adapter.       | By the Adapter:<br>Transmit the buffer data.                                     | Output Buffer Empty.<br>Buffer Owner: Program.  |
| Output Buffer Primed<br>Buffer Owner: Adapter.       | By the Adapter:<br>Transmit the buffer data.<br>HALT signal terminates transfer. | Output Buffer Halted<br>Buffer Owner: Program.  |
| Output Buffer Primed<br>Buffer Owner: Adapter        | By the Adapter:<br>Error detected during buffer processing.                      | Output Buffer Error.<br>Buffer Owner: Program.  |
| Output Buffer Halted<br>Buffer Owner: Program.       | By the Program:<br>Application dependent.                                        | Not Appl.. Q processing is terminated by HSCH.  |
| Output Buffer Error.<br>Buffer Owner: Program.       | By the Program:<br>Reclaim and refill buffer with data.                          | Output Buffer Primed.<br>Buffer Owner: Adapter. |

Figure 8 Allowed QDIO Output Queue Buffer State Transitions.

P09-99-014

Page 11 of 11

Word

|   |          |              |       |  |
|---|----------|--------------|-------|--|
| 0 | Flags    | Reserved     | SBALF |  |
| 1 | Reserved | Data Count   |       |  |
| 2 | Reserved |              |       |  |
| 3 | 0        | Data Address |       |  |

0 1 16 24 31

Figure 13. Storage-Block-Address-List Entry (SBALE)

Word

|    |        |        |        |        |
|----|--------|--------|--------|--------|
| 0  | SQB0   | SQB1   | SQB2   | SQB3   |
| 1  |        |        |        |        |
| 30 | //     |        |        | //     |
| 31 | SQB124 | SQB125 | SQB126 | SQB127 |

0 8 16 24 31

Figure 14 Storage-List-State Block

Docket No.  
PO9-99-014

# Declaration and Power of Attorney For Patent Application

## English Language Declaration

As a below named inventor, I hereby declare that:

My residence, post office address and citizenship are as stated below next to my name,

I believe I am the original, first and sole inventor (if only one name is listed below) or an original, first and joint inventor (if plural names are listed below) of the subject matter which is claimed and for which a patent is sought on the invention entitled

### AN APPARATUS FOR PROVIDING DIRECT DATA PROCESSING ACCESS USING A QUEUED DIRECT INPUT-OUTPUT DEVICE

the specification of which

(check one)

is attached hereto.

was filed on \_\_\_\_\_ as United States Application No. or PCT International Application Number \_\_\_\_\_

and was amended on \_\_\_\_\_

(if applicable)

I hereby state that I have reviewed and understand the contents of the above identified specification, including the claims, as amended by any amendment referred to above.

I acknowledge the duty to disclose to the United States Patent and Trademark Office all information known to me to be material to patentability as defined in Title 37, Code of Federal Regulations, Section 1.56.

I hereby claim foreign priority benefits under Title 35, United States Code, Section 119(a)-(d) or Section 365(b) of any foreign application(s) for patent or inventor's certificate, or Section 365(a) of any PCT International application which designated at least one country other than the United States, listed below and have also identified below, by checking the box, any foreign application for patent or inventor's certificate or PCT International application having a filing date before that of the application on which priority is claimed.

Prior Foreign Application(s)

Priority Not Claimed

|          |           |                        |                          |
|----------|-----------|------------------------|--------------------------|
| (Number) | (Country) | (Day/Month/Year Filed) | <input type="checkbox"/> |
| (Number) | (Country) | (Day/Month/Year Filed) | <input type="checkbox"/> |
| (Number) | (Country) | (Day/Month/Year Filed) | <input type="checkbox"/> |

I hereby claim the benefit under 35 U.S.C. Section 119(e) of any United States provisional application(s) listed below:

---

(Application Serial No.)

---

(Filing Date)

---

(Application Serial No.)

---

(Filing Date)

---

(Application Serial No.)

---

(Filing Date)

I hereby claim the benefit under 35 U. S. C. Section 120 of any United States application(s), or Section 365(c) of any PCT International application designating the United States, listed below and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior United States or PCT International application in the manner provided by the first paragraph of 35 U.S.C. Section 112, I acknowledge the duty to disclose to the United States Patent and Trademark Office all information known to me to be material to patentability as defined in Title 37, C. F. R., Section 1.56 which became available between the filing date of the prior application and the national or PCT International filing date of this application:

---

(Application Serial No.)

---

(Filing Date)

---

(Status)

(patented, pending, abandoned)

---

(Application Serial No.)

---

(Filing Date)

---

(Status)

(patented, pending, abandoned)

---

(Application Serial No.)

---

(Filing Date)

---

(Status)

(patented, pending, abandoned)

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

**POWER OF ATTORNEY:** As a named inventor, I hereby appoint the following attorney(s) and/or agent(s) to prosecute this application and transact all business in the Patent and Trademark Office connected therewith. (*list name and registration number*)

Lynn L. Augspurger, Reg. No. 24,227

Marc A. Ehrlich, Reg. No. 39,966

Floyd A. Gonzalez, Reg. No. 26,732

Lily Neff, Reg. No. 38,254

Christopher A. Hughes, Reg. No. 26,914

John E. Hoel, Reg. No. 26,279

Lawrence D. Cutter, Reg. No. 28,501

William A. Kinnaman, Jr., Reg. No. 27,650

Edward A. Pennington, Reg. No. 32,588

Joseph C. Redmond, Jr., Reg. No. 18,753

Bernard M. Goldman, Reg. No. 17,959

William B. Porter, Reg. No. 33,135

Send Correspondence to: **Lily Neff, Attorney**  
**IBM Corporation, Intellectual Property Law**  
**522 South Rd., M/S P386**  
**Poughkeepsie, NY 12601-5400**

Direct Telephone Calls to: (*name and telephone number*)

**Lily Neff (914) 433-1155**

|                                                                 |      |
|-----------------------------------------------------------------|------|
| Full name of sole or first inventor<br><b>Michael E. Baskey</b> | Date |
| Sole or first inventor's signature                              | Date |
| Residence<br><b>31 HiView Road, Wappingers Falls, NY 12590</b>  |      |
| Citizenship<br><b>U.S.A.</b>                                    |      |
| Post Office Address<br><b>Same as above</b>                     |      |
|                                                                 |      |

|                                                                  |      |
|------------------------------------------------------------------|------|
| Full name of second inventor, if any<br><b>Steven G. Glassen</b> | Date |
| Second inventor's signature                                      | Date |
| Residence<br><b>11 Sherwood Drive, Wallkill, NY 12589</b>        |      |
| Citizenship<br><b>U.S.A.</b>                                     |      |
| Post Office Address<br><b>Same as above</b>                      |      |
|                                                                  |      |

|                                                                  |      |
|------------------------------------------------------------------|------|
| Full name of third inventor, if any<br><b>Eugene P. Hefferon</b> | Date |
| Third inventor's signature                                       |      |
| Residence<br><b>77 Hillis Terrace, Poughkeepsie, NY 12603</b>    |      |
| Citizenship<br><b>U.S.A.</b>                                     |      |
| Post Office Address<br><b>Same as above</b>                      |      |
|                                                                  |      |

|                                                                  |      |
|------------------------------------------------------------------|------|
| Full name of fourth inventor, if any<br><b>Bruce H. Ratcliff</b> | Date |
| Fourth inventor's signature                                      |      |
| Residence<br><b>66 Manor Road, Red Hook, NY 12571</b>            |      |
| Citizenship<br><b>U.S.A.</b>                                     |      |
| Post Office Address<br><b>Same as above</b>                      |      |
|                                                                  |      |

|                                                               |      |
|---------------------------------------------------------------|------|
| Full name of fifth inventor, if any<br><b>Arthur J. Stagg</b> | Date |
| Fifth inventor's signature                                    |      |
| Residence<br><b>12613 Waterman Drive, Raleigh, NC 27614</b>   |      |
| Citizenship<br><b>U.S.A.</b>                                  |      |
| Post Office Address<br><b>Same as above</b>                   |      |
|                                                               |      |

|                                                                 |      |
|-----------------------------------------------------------------|------|
| Full name of sixth inventor, if any<br><b>Stephen R. Valley</b> | Date |
| Sixth inventor's signature                                      |      |
| Residence<br><b>15 Grandview Drive, Valatie, NY 12184</b>       |      |
| Citizenship<br><b>U.S.A.</b>                                    |      |
| Post Office Address<br><b>Same as above</b>                     |      |
|                                                                 |      |